

#### **Executive Summary**

- Motivation: We need a working ALU for the microprocessor design.
- Problem: We need to put together and test the building blocks for the microprocessor design.
- Overview:
  - ALU implementation and testing.
  - Introduce Project Logistics.
- Conclusion: We can implement an ALU using logic building blocks, and we can evaluate its design. We are ready to work in our microprocessor!



**Course Logistics** 



#### **Recall: Arithmetic Logic Unit**

- ALU is the heart of the processor.
- ALU should perform at least:
  - Addition
  - Subtraction
  - AND
  - OR

| ALUControl <sub>1:0</sub> | Function |
|---------------------------|----------|
| 00                        | Add      |
| 01                        | Subtract |
| 10                        | AND      |
| 11                        | OR       |



Example: Perform A + B ALUControl = 00Result = A + B



## **Inputs and Outputs**



#### **ALU OR**

| ALUControl <sub>1:0</sub> | Function |
|---------------------------|----------|
| 00                        | Add      |
| 01                        | Subtract |
| 10                        | AND      |
| 11                        | OR       |

#### **Example:** Perform A OR B

 $ALUControl_{1:0} = 11$ Mux selects output of OR gate as *Result*, so *Result = A OR B* 





#### **ALU ADD**

| ALUControl <sub>1:0</sub> | Function |
|---------------------------|----------|
| 00                        | Add      |
| 01                        | Subtract |
| 10                        | AND      |
| 11                        | OR       |

#### **Example:** Perform A + B

 $ALUControl_{1:0} = 00$   $ALUControl_0 = 0$ , so: Cin to adder = 0  $2^{nd}$  input to adder is B Mux selects Sum as Result, so Result = A + B





#### **Operation Logic**

```
assign condinvb = ALUControl[0] ? ~b : b;
assign sum = a + condinvb + ALUControl[0];

always @(*)
begin
   casex (ALUControl[1:0])
    2'b0?: Result = sum;
   2'b10: Result = a & b;
   2'b11: Result = a | b;
   endcase
end
```





#### **ALU with Status Flags**

| Flag | Description              |
|------|--------------------------|
| N    | Result is Negative       |
| Z    | Result is <b>Z</b> ero   |
| С    | Adder produces Carry out |
| V    | Adder oVerflowed         |





## **ALU with Status Flags**





### Flag Negative (N)



N = 1 if:

Result is negative

So, N is connected to most significant bit (msb) of Result



## Flag Zero (Z)



```
Z = 1 if:
all of the bits of Result
are 0
```

```
E.g.: Result = 0101

~Result = 1010

Z=AND(Result bits) = 0
```



# Flag Carry (C)



C = 1 if:

C<sub>out</sub> of Adder is 1

**AND** 

ALU is adding or subtracting (ALUControl is 00 or 01)



### Flag Overflow (V)



#### V = 1 if:

The addition of 2 samesigned numbers produces a result with the opposite sign



## Flag Overflow (V)







### Flags Assignment

```
assign neg
              = Result[31];
  assign zero
              = (Result == 32'b0);
  assign carry
                  = (ALUControl[1] ==
1'b0)
                     & sum[32];
  assign overflow = (ALUControl[1] ==
1'b0)
                     \& \sim (a[31] ^ b[31] ^
                         ALUControl[0]) &
(a[31]
                     ^ sum[31]);
  assign ALUFlags = {neg, zero, carry,
                              overflow};
endmodule
```



**Course Logistics** 



**Course Logistics** 



- We implemented an ALU that can be used as building blocks for our microprocessor.
- We evaluated the ALU using the testvector testbench.
- We conclude that the ALU enables our microprocessor design.



**Computer Architecture** 



CS3501 - 2025 I

PROF.: JGONZALEZ@UTEC.EDU.PE CWILLIAMS@UTEC.EDU.PE

